Ruby if .. elsIf .. else 在一行中?
全部标签 我与同事争论在if..elseblock中分配变量的最佳方法。他的原始代码是:@products=ifparams[:category]Category.find(params[:category]).productselseProduct.allend我是这样重写的:ifparams[:category]@products=Category.find(params[:category]).productselse@products=Product.allend这也可以使用三元运算符(?:)用单行代码重写,但我们假设产品分配的长度超过100个字符并且不能放在一行中。这两个你更清楚哪个?
我知道在Ruby中有一个简写的单行if/else语句:a?b:c是否只有一个if语句?而不是这样写:ifa#dosomethingend有这个的简写版本吗? 最佳答案 您可以使用后置条件(不要介意名称,它会在代码之前被评估。而do_something只会被如果条件评估为真值(即不是nil或false)则执行。do_somethingifa 关于ruby-RubyonRails中是否有简写if(没有else)语句?,我们在StackOverflow上找到一个类似的问题:
如果我有一个字符串数组,例如a=['a','b','c','d']我想将元素输出到文件(例如.txt),每行一个。到目前为止,我有:File.new("test.txt","w+")File.open("test.txt","w+")do|i|i.write(a)end这为我提供了test.txt文件中一行的数组。我如何遍历数组,将每个值添加到文件的新行? 最佳答案 要么使用Array#each遍历你的数组并调用IO#puts将每个元素写入文件(puts添加记录分隔符,通常是换行符):File.open("test.txt","w+
在Rails中,我经常遇到这样的情况,在View中我会做类似的事情123somethingelse看起来有点乱。这是处理View的可接受方式吗? 最佳答案 除非您能想出一种方法将其重写为辅助方法,否则您基本上只能坚持使用它,看起来有点丑陋。ERB就是这样,因为它旨在成为将Ruby注入(inject)其他纯文本模板的最小方式,而不是必须流线型或优雅的东西。好消息是语法高亮编辑器通常会让你的ERBblock在视觉上与您的HTML不同,因此可以显着提高可读性。这也是为什么其他表示形式如HAML的原因已经创建了语法不那么困惑的地方:-ifs
在elsif上使用elseif是否安全?使用elsif是否更好,因为它遵循Ruby的类型惯例?或者这是一种偏好?这是摘自一本书的一段代码。我添加了额外的end关键字并将elsif关键字替换为elseif。defdescribe(inhabitant)ifinhabitant=="sophie"puts'gender:female'puts'height:145'elseifinhabitant=="paul"puts'gender:male'puts'height:145'elseifinhabitant=="dawn"puts'gender:female'puts'height:17
我有一个Rails3.0.9应用程序,一旦部署,就会遇到一堆ActiveModel::MissingAttributeErrors,这些错误会突然出现并导致500秒。错误相当随机地发生,有时页面会加载,有时不会,但属性都是数据库中的现有属性,应该可以找到。奇怪的是,一段时间后,错误消失了。突然之间,它们不再引起问题。我已经搜索过这个问题的解决方案,但这个错误主要发生在有人完成Model.all(:select=>'column_x,column_y')并调用column_z或者当他们使用cache_money时。这些我都没有做。有人能帮忙吗? 最佳答案
我试图理解Ruby中的异常,但我有点困惑。我正在使用的教程说,如果发生与救援语句识别的任何异常都不匹配的异常,您可以使用“else”来捕获它:begin#-rescueOneTypeOfException#-rescueAnotherTypeOfException#-else#Otherexceptionsensure#Alwayswillbeexecutedend但是,我也看到在教程后面的“rescue”中没有指定异常就被使用了:beginfile=open("/unexistant_file")iffileputs"Fileopenedsuccessfully"endrescuef
这个问题在这里已经有了答案:Determiningifavariableiswithinrange?(10个答案)关闭7年前。是否有一种简单的方法可以使用(2..100)语法评估整数是否在该范围内。例如,如果我的整数x=100并且我的范围是(0..200),我想评估为真,我只是在看对于这样做的简单、简洁的ruby方式。
是否有一个ruby惯用法来表示“如果这样做”和“这样做”只是一个简单的命令?比如我现在在做object.method?a.action:nil将else子句留空,但我觉得可能有一种更惯用的方法可以做到这一点,而不必在末尾指定nil。(或者,我觉得在这种情况下使用多行代码会很浪费。 最佳答案 作为一般规则:您几乎不需要Ruby中的三元运算符。在C中需要它的原因是因为在C中if是一个语句,所以如果您想返回一个值,您必须使用三元运算符,即一个表达式。在Ruby中,一切都是表达式,没有语句,这使得三元运算符几乎是多余的。您可以随时更换c
我正在使用RubyonRails3.0.9,我想检查一个数字是否包含在一个范围内。也就是说,如果我有一个变量number=5我想查看1并在number时检索一个bool值值包含在该范围内。我可以这样做:number>=1&&number但我想在一个声明中做到这一点。我该怎么做? 最佳答案 (1..10).include?(number)是诀窍。顺便说一句:如果你想使用ActiveModel::Validations验证一个数字,你甚至可以这样做:validates_inclusion_of:number,:in=>1..10阅读he